

<!DOCTYPE html>
<html lang="zh-CN" data-default-color-scheme=auto>



<head>
  <meta charset="UTF-8">
  <link rel="apple-touch-icon" sizes="76x76" href="/img/egg.png">
  <link rel="icon" href="/img/egg.png">
  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=5.0, shrink-to-fit=no">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  
  <meta name="theme-color" content="#2f4154">
  <meta name="author" content="十一的蛋炒饭">
  <meta name="keywords" content="">
  
    <meta name="description" content="软件测试2  学习目标：  执行用例的案例 缺陷相关知识  12341. 能够说出软件缺陷判定标准2. 能输出项目中缺陷的管理流程3. 能使用 Excel 对于缺陷进行管理4. 能使用工具管理缺陷  1、软件生命周期软件生命周期（SDLC，System Development Life Cycle ）是软件开始研发到最终被废弃不用所经历的各个阶段。 1.1 瀑布型生命周期模型瀑布型生命周期模型也叫">
<meta property="og:type" content="article">
<meta property="og:title" content="软件测试笔记2 | 软件生命周期、缺陷管理">
<meta property="og:url" content="http://example.com/2024/04/05/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95%E7%AC%94%E8%AE%B02-%E8%BD%AF%E4%BB%B6%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E3%80%81%E7%BC%BA%E9%99%B7%E7%AE%A1%E7%90%86/index.html">
<meta property="og:site_name" content="十一的蛋炒饭的博客">
<meta property="og:description" content="软件测试2  学习目标：  执行用例的案例 缺陷相关知识  12341. 能够说出软件缺陷判定标准2. 能输出项目中缺陷的管理流程3. 能使用 Excel 对于缺陷进行管理4. 能使用工具管理缺陷  1、软件生命周期软件生命周期（SDLC，System Development Life Cycle ）是软件开始研发到最终被废弃不用所经历的各个阶段。 1.1 瀑布型生命周期模型瀑布型生命周期模型也叫">
<meta property="og:locale" content="zh_CN">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021520726.png">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021523759.png">
<meta property="og:image" content="https://file.boxuegu.com/5bf3527095bc414087cc1e9af9eac706.png">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021546027.png">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012016283.png">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012152379.png">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012219972.png">
<meta property="og:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012242456.png">
<meta property="article:published_time" content="2024-04-05T05:46:00.000Z">
<meta property="article:modified_time" content="2024-04-05T05:46:48.194Z">
<meta property="article:author" content="十一的蛋炒饭">
<meta property="article:tag" content="软件测试">
<meta property="article:tag" content="缺陷管理">
<meta name="twitter:card" content="summary_large_image">
<meta name="twitter:image" content="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021520726.png">
  
  
  
  <title>软件测试笔记2 | 软件生命周期、缺陷管理 - 十一的蛋炒饭的博客</title>

  <link  rel="stylesheet" href="https://lib.baomitu.com/twitter-bootstrap/4.6.1/css/bootstrap.min.css" />



  <link  rel="stylesheet" href="https://lib.baomitu.com/github-markdown-css/4.0.0/github-markdown.min.css" />

  <link  rel="stylesheet" href="https://lib.baomitu.com/hint.css/2.7.0/hint.min.css" />

  <link  rel="stylesheet" href="https://lib.baomitu.com/fancybox/3.5.7/jquery.fancybox.min.css" />



<!-- 主题依赖的图标库，不要自行修改 -->
<!-- Do not modify the link that theme dependent icons -->

<link rel="stylesheet" href="//at.alicdn.com/t/font_1749284_hj8rtnfg7um.css">



<link rel="stylesheet" href="//at.alicdn.com/t/font_1736178_lbnruvf0jn.css">


<link  rel="stylesheet" href="/css/main.css" />


  <link id="highlight-css" rel="stylesheet" href="/css/highlight.css" />
  
    <link id="highlight-css-dark" rel="stylesheet" href="/css/highlight-dark.css" />
  




  <script id="fluid-configs">
    var Fluid = window.Fluid || {};
    Fluid.ctx = Object.assign({}, Fluid.ctx)
    var CONFIG = {"hostname":"example.com","root":"/","version":"1.9.7","typing":{"enable":true,"typeSpeed":60,"cursorChar":"","loop":false,"scope":["home"]},"anchorjs":{"enable":true,"element":"h1,h2,h3,h4,h5,h6","placement":"left","visible":"hover","icon":"§"},"progressbar":{"enable":true,"height_px":3,"color":"#29d","options":{"showSpinner":false,"trickleSpeed":100}},"code_language":{"enable":true,"default":"TEXT"},"copy_btn":true,"image_caption":{"enable":true},"image_zoom":{"enable":true,"img_url_replace":["",""]},"toc":{"enable":true,"placement":"right","headingSelector":"h1,h2,h3,h4,h5,h6","collapseDepth":0},"lazyload":{"enable":true,"loading_img":"/img/loading.gif","onlypost":false,"offset_factor":2},"web_analytics":{"enable":false,"follow_dnt":true,"baidu":null,"google":{"measurement_id":null},"tencent":{"sid":null,"cid":null},"woyaola":null,"cnzz":null,"leancloud":{"app_id":null,"app_key":null,"server_url":null,"path":"window.location.pathname","ignore_local":false}},"search_path":"/local-search.xml","include_content_in_search":true};

    if (CONFIG.web_analytics.follow_dnt) {
      var dntVal = navigator.doNotTrack || window.doNotTrack || navigator.msDoNotTrack;
      Fluid.ctx.dnt = dntVal && (dntVal.startsWith('1') || dntVal.startsWith('yes') || dntVal.startsWith('on'));
    }
  </script>
  <script  src="/js/utils.js" ></script>
  <script  src="/js/color-schema.js" ></script>
  


  
<meta name="generator" content="Hexo 7.1.1"></head>


<body>
  

  <header>
    

<div class="header-inner" style="height: 70vh;">
  <nav id="navbar" class="navbar fixed-top  navbar-expand-lg navbar-dark scrolling-navbar">
  <div class="container">
    <a class="navbar-brand" href="/">
      <strong>十一的蛋炒饭 的博客</strong>
    </a>

    <button id="navbar-toggler-btn" class="navbar-toggler" type="button" data-toggle="collapse"
            data-target="#navbarSupportedContent"
            aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
      <div class="animated-icon"><span></span><span></span><span></span></div>
    </button>

    <!-- Collapsible content -->
    <div class="collapse navbar-collapse" id="navbarSupportedContent">
      <ul class="navbar-nav ml-auto text-center">
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/" target="_self">
                <i class="iconfont icon-home-fill"></i>
                <span>首页</span>
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/archives/" target="_self">
                <i class="iconfont icon-archive-fill"></i>
                <span>归档</span>
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/categories/" target="_self">
                <i class="iconfont icon-category-fill"></i>
                <span>分类</span>
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/tags/" target="_self">
                <i class="iconfont icon-tags-fill"></i>
                <span>标签</span>
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/about/" target="_self">
                <i class="iconfont icon-user-fill"></i>
                <span>关于</span>
              </a>
            </li>
          
        
        
          <li class="nav-item" id="search-btn">
            <a class="nav-link" target="_self" href="javascript:;" data-toggle="modal" data-target="#modalSearch" aria-label="Search">
              <i class="iconfont icon-search"></i>
            </a>
          </li>
          
        
        
          <li class="nav-item" id="color-toggle-btn">
            <a class="nav-link" target="_self" href="javascript:;" aria-label="Color Toggle">
              <i class="iconfont icon-dark" id="color-toggle-icon"></i>
            </a>
          </li>
        
      </ul>
    </div>
  </div>
</nav>

  

<div id="banner" class="banner" parallax=true
     style="background: url('/img/win7.jpg') no-repeat center center; background-size: cover;">
  <div class="full-bg-img">
    <div class="mask flex-center" style="background-color: rgba(0, 0, 0, 0.3)">
      <div class="banner-text text-center fade-in-up">
        <div class="h2">
          
            <span id="subtitle">软件测试笔记2 | 软件生命周期、缺陷管理</span>
          
        </div>

        
          
  <div class="mt-3">
    
    
      <span class="post-meta">
        <i class="iconfont icon-date-fill" aria-hidden="true"></i>
        <time datetime="2024-04-05 13:46" pubdate>
          2024年4月5日 下午
        </time>
      </span>
    
  </div>

  <div class="mt-1">
    
      <span class="post-meta mr-2">
        <i class="iconfont icon-chart"></i>
        
          2.7k 字
        
      </span>
    

    
      <span class="post-meta mr-2">
        <i class="iconfont icon-clock-fill"></i>
        
        
        
          23 分钟
        
      </span>
    

    
    
  </div>


        
      </div>

      
    </div>
  </div>
</div>

</div>

  </header>

  <main>
    
      

<div class="container-fluid nopadding-x">
  <div class="row nomargin-x">
    <div class="side-col d-none d-lg-block col-lg-2">
      
  <aside class="sidebar category-bar" style="margin-right: -1rem">
    





<div class="category-list">
  
  
    
    
    
    <div class="category row nomargin-x">
      <a class="category-item 
          list-group-item category-item-action col-10 col-md-11 col-xm-11" title="软件测试"
        id="heading-99a272194eb867ea363eec81b5e38d12" role="tab" data-toggle="collapse" href="#collapse-99a272194eb867ea363eec81b5e38d12"
        aria-expanded="true"
      >
        软件测试
        <span class="list-group-count">(2)</span>
        <i class="iconfont icon-arrowright"></i>
      </a>
      
      <div class="category-collapse collapse show" id="collapse-99a272194eb867ea363eec81b5e38d12"
           role="tabpanel" aria-labelledby="heading-99a272194eb867ea363eec81b5e38d12">
        
        
          
  <div class="category-post-list">
    
    
      
      
        <a href="/2024/03/31/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95%E7%AC%94%E8%AE%B01-%E5%9F%BA%E6%9C%AC%E6%A6%82%E5%BF%B5%E3%80%81%E4%B8%BB%E6%B5%81%E6%8A%80%E8%83%BD%E3%80%81%E8%BD%AF%E6%B5%8B%E6%B5%81%E7%A8%8B%E3%80%81%E6%B5%8B%E8%AF%95%E7%94%A8%E4%BE%8B%E3%80%81%E7%AD%89%E4%BB%B7%E7%B1%BB%E5%88%92%E5%88%86%E6%B3%95%E3%80%81%E8%BE%B9%E7%95%8C%E5%80%BC%E5%88%86%E6%9E%90%E6%B3%95%E3%80%81%E5%88%A4%E5%AE%9A%E8%A1%A8%E6%B3%95%E3%80%81%E9%94%99%E8%AF%AF%E6%8E%A8%E8%8D%90%E6%B3%95/" title="软件测试笔记1| 基本概念、主流技能、软测流程、测试用例、等价类划分法、边界值分析法、判定表法、错误推荐法"
           class="list-group-item list-group-item-action
           ">
          <span class="category-post">软件测试笔记1| 基本概念、主流技能、软测流程、测试用例、等价类划分法、边界值分析法、判定表法、错误推荐法</span>
        </a>
      
    
      
      
        <a href="/2024/04/05/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95%E7%AC%94%E8%AE%B02-%E8%BD%AF%E4%BB%B6%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E3%80%81%E7%BC%BA%E9%99%B7%E7%AE%A1%E7%90%86/" title="软件测试笔记2 | 软件生命周期、缺陷管理"
           class="list-group-item list-group-item-action
           active">
          <span class="category-post">软件测试笔记2 | 软件生命周期、缺陷管理</span>
        </a>
      
    
  </div>

        
      </div>
    </div>
  
</div>


  </aside>


    </div>

    <div class="col-lg-8 nopadding-x-md">
      <div class="container nopadding-x-md" id="board-ctn">
        <div id="board">
          <article class="post-content mx-auto">
            <h1 id="seo-header">软件测试笔记2 | 软件生命周期、缺陷管理</h1>
            
              <p id="updated-time" class="note note-info" style="display: none">
                
                  
                    本文最后更新于 2024-04-05T13:46:48+08:00
                  
                  

                
              </p>
            
            
              <div class="markdown-body">
                
                <p>软件测试2 </p>
<p><strong>学习目标：</strong></p>
<ol>
<li>执行用例的案例</li>
<li>缺陷相关知识</li>
</ol>
<figure class="highlight markdown"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br></pre></td><td class="code"><pre><code class="hljs markdown"><span class="hljs-bullet">1.</span> 能够说出软件缺陷判定标准<br><span class="hljs-bullet">2.</span> 能输出项目中缺陷的管理流程<br><span class="hljs-bullet">3.</span> 能使用 Excel 对于缺陷进行管理<br><span class="hljs-bullet">4.</span> 能使用工具管理缺陷<br></code></pre></td></tr></table></figure>

<h2 id="1、软件生命周期"><a href="#1、软件生命周期" class="headerlink" title="1、软件生命周期"></a>1、软件生命周期</h2><p>软件生命周期（SDLC，System Development Life Cycle ）是软件<strong>开始研发</strong>到<strong>最终被废弃不用</strong>所经历的各个阶段。</p>
<h3 id="1-1-瀑布型生命周期模型"><a href="#1-1-瀑布型生命周期模型" class="headerlink" title="1.1 瀑布型生命周期模型"></a>1.1 瀑布型生命周期模型</h3><p>瀑布型生命周期模型也叫瀑布模型，规定了它们自上而下，相互衔接的固定次序，如同瀑布流水，逐级下落，具有顺序性和依赖性。</p>
<p>每个阶段规定文档并需进行评审。（该模型在企业中已经基本不用）</p>
<p><img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021520726.png" srcset="/img/loading.gif" lazyload alt="image-20240402152000658"></p>
<h3 id="1-2-V-模型"><a href="#1-2-V-模型" class="headerlink" title="1.2 V 模型"></a>1.2 V 模型</h3><p>RAD（Rap Application Development，快速应用开发）模型是软件开发过程中的一个重要模型，由于其模型构图类似字母V，所以又称软件开发的V模型，它通过开发和测试<strong>同时进行</strong>的方式来缩短开发周期，提高开发效率。</p>
<p><img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021523759.png" srcset="/img/loading.gif" lazyload alt="image-20240402152313700"></p>
<p>V模型中，在需求分析阶段，测试就已经介入了。</p>
<h3 id="1-3-软件生命周期各个阶段"><a href="#1-3-软件生命周期各个阶段" class="headerlink" title="1.3 软件生命周期各个阶段"></a>1.3 软件生命周期各个阶段</h3><p><strong>1、问题的定义及规划</strong></p>
<ul>
<li>主要确定软件的开发目的及其可行性。制定项目总体开发计划。</li>
</ul>
<p><strong>2、需求分析</strong></p>
<ul>
<li>在确定软件开发可行的情况下，对软件需要实现的各个功能进行详细分析，明确客户的需求，输出需求规格说明书终版（原型图），提交评审。</li>
</ul>
<p><strong>3、设计</strong></p>
<ul>
<li>把需求分析得到的结果转换为软件结构和数据结构，形成系统架构。</li>
<li>概要设计：主要说明架构的实现，指搭建架构、表述模块功能、模块接口连接和数据传递的实现等项事务。</li>
<li>详细设计：对概要设计中表述的各模块进行深入分析等，其中需要包含数据库设计说明。</li>
</ul>
<p><strong>4、编码</strong></p>
<ul>
<li>按照详细设计好的模块功能表，编程人员编写出计算机可运行的程序代码。</li>
</ul>
<p><strong>5、软件测试（重要）</strong></p>
<p>在软件设计完成后要经过严密的测试，以发现软件在整个设计过程中存在的问题并加以纠正。</p>
<p>测试的方法主要有白盒测试和黑盒测试两种，都是建立详细的测试计划并严格按照计划进行。</p>
<ul>
<li><strong>单元测试：</strong>主要是测试程序代码，目的是确保单元模块被正确的编译，比如有具体到模块的测试，也有具体到类、函数、方法的测试等。（一般是开发完成）</li>
<li><strong>集成测试：</strong>单元测试后，将个单元组合成完整的体系，测试软件单位之间的接口是否正确、数据是否正常传递。（比如注册和充值这两个功能是否连通）</li>
<li><strong>系统测试：</strong>把软件系统搭建好后，按照软件规格说明书中所要求，测试软件及其性能功能等是否和用户需求相符合，在系统中运行是否存在漏洞等。（根据测试用例，进行完整的系统测试）</li>
<li><strong>验收测试：</strong> 主要就是用户在拿到软件的时候，在使用现场，会根据前边所提到的需求，以及规格说明书来做相应测试，以确定软件达到符合效果。（用户对软件进行验收）</li>
</ul>
<p><strong>6、运行维护</strong></p>
<p><strong>软件维护</strong>是软件生命周期中持续时间最长的阶段。在软件开发完成并投入使用后，由于多方面的原因，软件不能继续适应用户的需求。要延续软件的使用寿命，就必须对软件进行维护。软件的维护主要包括<strong>纠错性维护</strong>和<strong>改进型维护</strong>两个方面。</p>
<h3 id="1-4-敏捷开发模型"><a href="#1-4-敏捷开发模型" class="headerlink" title="1.4 敏捷开发模型"></a>1.4 敏捷开发模型</h3><p>注：敏捷开发模型是目前互联网公司用的最多的开发模型。</p>
<p>从 1990 年代开始逐渐引起广泛关注。</p>
<p><strong>敏捷开发模型 <strong>是一种以人为核心、迭代、循序渐进的开发方法，是一个用于开发和维护复杂产品的框架，把一个大项目分为多个相互联系，但也可独立运行的小项目，并分别完成，在此过程中软件</strong>一直处于</strong>可使用状态。</p>
<p><img src="https://file.boxuegu.com/5bf3527095bc414087cc1e9af9eac706.png" srcset="/img/loading.gif" lazyload alt="敏捷开发流程"></p>
<h3 id="1-5-软件测试工作流程图"><a href="#1-5-软件测试工作流程图" class="headerlink" title="1.5 软件测试工作流程图"></a>1.5 软件测试工作流程图</h3><p>软件测试工作流程图如下：</p>
<p><img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404021546027.png" srcset="/img/loading.gif" lazyload alt="image-20240402154605952"></p>
<p>软件测试的基本流程图（文字描述）</p>
<p><strong>1、测试需求分析阶段：</strong>阅读需求、理解需求，主要就是对业务的学习，分析需求点。参与需求评审会议。</p>
<p><strong>2、测试计划阶段：</strong> 主要任务是编写测试计划，参考软件需求规格说明书、项目总体计划，内容包括测试范围（来自需求文档）、进度的安排，人力物力的分配，整体测试策略的判定，和风险的评估与规避措施都有一个判定。</p>
<p><strong>3、测试设计阶段：</strong>主要任务是编写测试用例，会参考需求文档（原型图）、概要设计、详细设计等文档，有不明确的也会及时和开发、产品经理沟通。用例编写完成后会进行评审。</p>
<p><strong>4、测试执行阶段：</strong>首先搭建测试环境，执行预测（冒烟测试），以判定当前版本是否可测，若预测通过，则正式进入系统测试，遇到问题提交BUG到缺陷管理平台，并对BUG进行跟踪，直到被测软件达到测试需求要求，无重大BUG，测试结束（完善测试用例）</p>
<p><strong>5、测试评估阶段：</strong>出测试报告，对整个测试的过程和版本质量做一个详细的评估。确认是否可以上线。</p>
<h2 id="2、完善用例测试文档"><a href="#2、完善用例测试文档" class="headerlink" title="2、完善用例测试文档"></a>2、完善用例测试文档</h2><p>在之前的学习当中可以知道，用例测试文档一般有八个列，分别是：</p>
<figure class="highlight 1c"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs 1c">软件测试笔记<span class="hljs-number">1</span><span class="hljs-string">| 基本概念、主流技能、软测流程、测试用例、等价类划分法、边界值分析法、判定表法、错误推荐法</span><br></code></pre></td></tr></table></figure>

<ol>
<li>用例编号</li>
<li>用例标题</li>
<li>项目&#x2F;模块</li>
<li>优先级</li>
<li>前置条件</li>
<li>测试步骤</li>
<li>测试数据</li>
<li>预期结果</li>
</ol>
<p>除了这八项以外，还有最后一项 <code>实际结果</code>，这一项表示的是测试样例是否测试成功，通常只有 “通过” 或 “不通过” 这两个值。</p>
<h2 id="3、缺陷的基本概念"><a href="#3、缺陷的基本概念" class="headerlink" title="3、缺陷的基本概念"></a>3、缺陷的基本概念</h2><p>缺陷定义：软件在使用过程中存在的任何<strong>问题</strong>都叫软件的缺陷，简称BUG。</p>
<h3 id="3-1-缺陷的判定标准"><a href="#3-1-缺陷的判定标准" class="headerlink" title="3.1 缺陷的判定标准"></a>3.1 缺陷的判定标准</h3><p>缺陷的判定标准有以下5点：</p>
<ul>
<li><strong>少功能：</strong>软件为实现需求（规格）说明书中明确要求的功能。</li>
<li><strong>功能错误：</strong>软件出现了需求（规格）说明书中不应该出现的错误。</li>
<li><strong>多功能：</strong>软件实现的功能超出需求（规格）说明书中指明的范围。</li>
<li><strong>隐性功能错误：</strong>软件未实现需求（规格）说明书中虽未明确指明但应该实现的要求。</li>
<li><strong>不易使用：</strong>软件难以理解，不易使用，运行缓慢，用户体验不好等。</li>
</ul>
<h3 id="3-2-缺陷产生的原因"><a href="#3-2-缺陷产生的原因" class="headerlink" title="3.2 缺陷产生的原因"></a>3.2 缺陷产生的原因</h3><p><strong>需求阶段：</strong>需求不易理解，有歧义、错误等。</p>
<p><strong>设计阶段：</strong>设计文档存在错误或者缺陷。</p>
<p><strong>编码阶段：</strong>代码出现错误。</p>
<p><strong>运行阶段：</strong>软硬件系统本身故障导致软件缺陷。</p>
<h3 id="3-3-缺陷生命周期"><a href="#3-3-缺陷生命周期" class="headerlink" title="3.3 缺陷生命周期"></a>3.3 缺陷生命周期</h3><p>软件开发和缺陷处理的生命周期如下图：</p>
<p><img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012016283.png" srcset="/img/loading.gif" lazyload alt="image-20240401201636205"></p>
<h3 id="3-4-缺陷核心内容"><a href="#3-4-缺陷核心内容" class="headerlink" title="3.4 缺陷核心内容"></a>3.4 缺陷核心内容</h3><ul>
<li>标题：描述缺陷的核心问题。</li>
<li>预期结果：希望得到的结果。</li>
<li>预置条件：缺陷产生的前提。</li>
<li>实际结果：实际得到的结果。</li>
<li>复现步骤：复现缺陷的过程。</li>
<li>必要条件：图片、日志等信息（证据）。</li>
</ul>
<h3 id="3-5-缺陷提交要素"><a href="#3-5-缺陷提交要素" class="headerlink" title="3.5 缺陷提交要素"></a>3.5 缺陷提交要素</h3><p>软件缺陷的提交要素主要有5项，分别是缺陷报告编号、严重程度、缺陷优先级、BUG类型、缺陷状态。</p>
<ol>
<li><strong>缺陷报告编号：</strong>缺陷的唯一性标志</li>
<li><strong>严重程度：</strong></li>
</ol>
<figure class="highlight armasm"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br></pre></td><td class="code"><pre><code class="hljs armasm">严重（<span class="hljs-built_in">S1</span>）：主功能<br>一般（<span class="hljs-built_in">S2</span>）：次要功能<br>微小（<span class="hljs-built_in">S3</span>）：易用性、界面<br>建议（<span class="hljs-built_in">S4</span>）：建议性问题<br></code></pre></td></tr></table></figure>

<ol start="3">
<li><strong>缺陷优先级</strong></li>
</ol>
<figure class="highlight apache"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br></pre></td><td class="code"><pre><code class="hljs apache"><span class="hljs-attribute">Priority</span> <span class="hljs-number">0</span>：<span class="hljs-number">24</span>小时之内解决<br><span class="hljs-attribute">Priority</span> <span class="hljs-number">1</span>：发布前必须修复<br><span class="hljs-attribute">Priority</span> <span class="hljs-number">2</span>：可以在下一个版本中修复<br></code></pre></td></tr></table></figure>

<ol start="4">
<li><strong>BUG 类型：</strong>代码错误、兼容性问题、设计缺陷、性能问题</li>
<li><strong>缺陷状态：</strong></li>
</ol>
<figure class="highlight vhdl"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br></pre></td><td class="code"><pre><code class="hljs vhdl"><span class="hljs-keyword">New</span>：新建<br><span class="hljs-keyword">Open</span>：打开<br>Closed：关闭<br><span class="hljs-keyword">Postponed</span>：延期<br></code></pre></td></tr></table></figure>



<h3 id="3-6-缺陷类型"><a href="#3-6-缺陷类型" class="headerlink" title="3.6 缺陷类型"></a>3.6 缺陷类型</h3><p><strong>软件缺陷类型：</strong></p>
<figure class="highlight markdown"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><code class="hljs markdown"><span class="hljs-bullet">1.</span> 功能错误<br><span class="hljs-bullet">2.</span> 界面（UI）错误<br><span class="hljs-bullet">3.</span> 兼容性<br><span class="hljs-bullet">4.</span> 数据（数据库）<br><span class="hljs-bullet">5.</span> 易用性<br><span class="hljs-bullet">6.</span> 改用建议<br><span class="hljs-bullet">7.</span> 架构缺陷<br></code></pre></td></tr></table></figure>

<p><strong>工作流程：</strong></p>
<figure class="highlight mipsasm"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br></pre></td><td class="code"><pre><code class="hljs mipsasm">设计用例 —&gt; 执行用例（执行测试) —&gt; 缺陷（提交、验证、关闭）<br>缺陷定义：任何问题（<span class="hljs-keyword">BUG）</span><br><span class="hljs-keyword"></span>缺陷标准：多功能、少功能、错误、缺少隐性功能、易用性<br>描述缺陷：缺陷标题、前置条件、复现步骤、预期结果、实际结果、附件备注<br>提交缺陷信息：指派人、缺陷等级、修复优先级、类型。状态（统计缺陷）<br></code></pre></td></tr></table></figure>



<h2 id="4、缺陷管理"><a href="#4、缺陷管理" class="headerlink" title="4、缺陷管理"></a>4、缺陷管理</h2><p><strong>缺陷报告示例：</strong></p>
<table>
<thead>
<tr>
<th>缺陷ID</th>
<th>缺陷标题</th>
<th>缺陷状态</th>
<th>严重程度</th>
<th>优先级</th>
<th>所属模块</th>
<th>缺陷描述</th>
<th>附件</th>
</tr>
</thead>
<tbody><tr>
<td>bug101</td>
<td>正常下单成功后支付失败</td>
<td>new</td>
<td>P0</td>
<td>P0</td>
<td>Ego核心业务</td>
<td>1、打开小程序；2、选中商品添加购物车进行下单；3、在订单详情点击付款；预期结果：能够呼起微信支付；实际结果：无响应</td>
<td>BUG的图片（略）</td>
</tr>
</tbody></table>
<h3 id="4-1-缺陷的跟踪流程"><a href="#4-1-缺陷的跟踪流程" class="headerlink" title="4.1 缺陷的跟踪流程"></a>4.1 缺陷的跟踪流程</h3><p><img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012152379.png" srcset="/img/loading.gif" lazyload alt="image-20240401215201242"></p>
<figure class="highlight"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs">提示：知道测试和开发流程中涉及的工作即可。<br></code></pre></td></tr></table></figure>

<h3 id="4-2-缺陷编写规范"><a href="#4-2-缺陷编写规范" class="headerlink" title="4.2 缺陷编写规范"></a>4.2 缺陷编写规范</h3><p><strong>缺陷编写规范主要有四个：</strong></p>
<ul>
<li><strong>准确：</strong>描述的信息是正确的。</li>
<li><strong>具体：</strong>有细节且是真实特定的。</li>
<li><strong>简洁易懂：</strong>描述简单容易理解。</li>
<li><strong>次序清晰：</strong>描述缺陷过程有条件，有先后顺序。</li>
</ul>
<h3 id="4-3-提交注意事项"><a href="#4-3-提交注意事项" class="headerlink" title="4.3 提交注意事项"></a>4.3 提交注意事项</h3><ul>
<li><strong>可重现：</strong>缺陷可以复现</li>
<li><strong>唯一性：</strong>一个缺陷上报一个问题</li>
<li><strong>规范性：</strong>符合公司或者项目要求</li>
</ul>
<p><strong>面试题：</strong>发现缺陷后，首先该怎么办？</p>
<p><strong>回答：</strong> 确定缺陷可重现，确定是缺陷，提交前要检查缺陷是否已存在，若不存在则提交缺陷。</p>
<h2 id="5、缺陷管理工具"><a href="#5、缺陷管理工具" class="headerlink" title="5、缺陷管理工具"></a>5、缺陷管理工具</h2><h3 id="5-1-禅道"><a href="#5-1-禅道" class="headerlink" title="5.1 禅道"></a>5.1 禅道</h3><p><strong>禅道特点：</strong></p>
<ul>
<li>国产、免费、开源、简单、轻量级</li>
<li>三管融合（产品管理、项目管理、质量管理）</li>
</ul>
<p><strong>三权分立：</strong></p>
<ul>
<li>产品部门 —— 构思者</li>
<li>研发部门 —— 执行者</li>
<li>测试部分 —— 保证者</li>
</ul>
<p><strong>四角协同：</strong></p>
<ul>
<li>产品经理</li>
<li>项目经理</li>
<li>研发团队</li>
<li>测试团队</li>
</ul>
<p>禅道在线演示网址：<a target="_blank" rel="noopener" href="https://zentao.demo.qucheng.cc/my.html">地盘 - 禅道 (qucheng.cc)</a></p>
<p><img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012219972.png" srcset="/img/loading.gif" lazyload alt="image-20240401221911901"></p>
<p><strong>禅道使用流程：</strong></p>
<img src="https://uni-pic-bed.oss-cn-hangzhou.aliyuncs.com/blog2024/202404012242456.png" srcset="/img/loading.gif" lazyload alt="image-20240401224257401" style="zoom:80%;" />




                
              </div>
            
            <hr/>
            <div>
              <div class="post-metas my-3">
  
    <div class="post-meta mr-3 d-flex align-items-center">
      <i class="iconfont icon-category"></i>
      

<span class="category-chains">
  
  
    
      <span class="category-chain">
        
  <a href="/categories/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95/" class="category-chain-item">软件测试</a>
  
  

      </span>
    
  
</span>

    </div>
  
  
    <div class="post-meta">
      <i class="iconfont icon-tags"></i>
      
        <a href="/tags/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95/" class="print-no-link">#软件测试</a>
      
        <a href="/tags/%E7%BC%BA%E9%99%B7%E7%AE%A1%E7%90%86/" class="print-no-link">#缺陷管理</a>
      
    </div>
  
</div>


              
  

  <div class="license-box my-3">
    <div class="license-title">
      <div>软件测试笔记2 | 软件生命周期、缺陷管理</div>
      <div>http://example.com/2024/04/05/软件测试笔记2-软件生命周期、缺陷管理/</div>
    </div>
    <div class="license-meta">
      
        <div class="license-meta-item">
          <div>作者</div>
          <div>十一的蛋炒饭</div>
        </div>
      
      
        <div class="license-meta-item license-meta-date">
          <div>发布于</div>
          <div>2024年4月5日</div>
        </div>
      
      
      
        <div class="license-meta-item">
          <div>许可协议</div>
          <div>
            
              
              
                <a class="print-no-link" target="_blank" href="https://creativecommons.org/licenses/by/4.0/">
                  <span class="hint--top hint--rounded" aria-label="BY - 署名">
                    <i class="iconfont icon-by"></i>
                  </span>
                </a>
              
            
          </div>
        </div>
      
    </div>
    <div class="license-icon iconfont"></div>
  </div>



              
                <div class="post-prevnext my-3">
                  <article class="post-prev col-6">
                    
                    
                  </article>
                  <article class="post-next col-6">
                    
                    
                      <a href="/2024/03/31/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95%E7%AC%94%E8%AE%B01-%E5%9F%BA%E6%9C%AC%E6%A6%82%E5%BF%B5%E3%80%81%E4%B8%BB%E6%B5%81%E6%8A%80%E8%83%BD%E3%80%81%E8%BD%AF%E6%B5%8B%E6%B5%81%E7%A8%8B%E3%80%81%E6%B5%8B%E8%AF%95%E7%94%A8%E4%BE%8B%E3%80%81%E7%AD%89%E4%BB%B7%E7%B1%BB%E5%88%92%E5%88%86%E6%B3%95%E3%80%81%E8%BE%B9%E7%95%8C%E5%80%BC%E5%88%86%E6%9E%90%E6%B3%95%E3%80%81%E5%88%A4%E5%AE%9A%E8%A1%A8%E6%B3%95%E3%80%81%E9%94%99%E8%AF%AF%E6%8E%A8%E8%8D%90%E6%B3%95/" title="软件测试笔记1| 基本概念、主流技能、软测流程、测试用例、等价类划分法、边界值分析法、判定表法、错误推荐法">
                        <span class="hidden-mobile">软件测试笔记1| 基本概念、主流技能、软测流程、测试用例、等价类划分法、边界值分析法、判定表法、错误推荐法</span>
                        <span class="visible-mobile">下一篇</span>
                        <i class="iconfont icon-arrowright"></i>
                      </a>
                    
                  </article>
                </div>
              
            </div>

            
          </article>
        </div>
      </div>
    </div>

    <div class="side-col d-none d-lg-block col-lg-2">
      
  <aside class="sidebar" style="margin-left: -1rem">
    <div id="toc">
  <p class="toc-header">
    <i class="iconfont icon-list"></i>
    <span>目录</span>
  </p>
  <div class="toc-body" id="toc-body"></div>
</div>



  </aside>


    </div>
  </div>
</div>





  



  



  



  



  







    

    
      <a id="scroll-top-button" aria-label="TOP" href="#" role="button">
        <i class="iconfont icon-arrowup" aria-hidden="true"></i>
      </a>
    

    
      <div class="modal fade" id="modalSearch" tabindex="-1" role="dialog" aria-labelledby="ModalLabel"
     aria-hidden="true">
  <div class="modal-dialog modal-dialog-scrollable modal-lg" role="document">
    <div class="modal-content">
      <div class="modal-header text-center">
        <h4 class="modal-title w-100 font-weight-bold">搜索</h4>
        <button type="button" id="local-search-close" class="close" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body mx-3">
        <div class="md-form mb-5">
          <input type="text" id="local-search-input" class="form-control validate">
          <label data-error="x" data-success="v" for="local-search-input">关键词</label>
        </div>
        <div class="list-group" id="local-search-result"></div>
      </div>
    </div>
  </div>
</div>

    

    
  </main>

  <footer>
    <div class="footer-inner">
  
    <div class="footer-content">
       <a href="https://hexo.io" target="_blank" rel="nofollow noopener"><span>博客网站基于Hexo</span></a> <i class="iconfont icon-love"></i> <a href="https://github.com/fluid-dev/hexo-theme-fluid" target="_blank" rel="nofollow noopener"><span>主题Fluid</span></a> 
    </div>
  
  
  
  
</div>

  </footer>

  <!-- Scripts -->
  
  <script  src="https://lib.baomitu.com/nprogress/0.2.0/nprogress.min.js" ></script>
  <link  rel="stylesheet" href="https://lib.baomitu.com/nprogress/0.2.0/nprogress.min.css" />

  <script>
    NProgress.configure({"showSpinner":false,"trickleSpeed":100})
    NProgress.start()
    window.addEventListener('load', function() {
      NProgress.done();
    })
  </script>


<script  src="https://lib.baomitu.com/jquery/3.6.4/jquery.min.js" ></script>
<script  src="https://lib.baomitu.com/twitter-bootstrap/4.6.1/js/bootstrap.min.js" ></script>
<script  src="/js/events.js" ></script>
<script  src="/js/plugins.js" ></script>





  
    <script  src="/js/img-lazyload.js" ></script>
  




  
<script>
  var relativeDate = function() {
    var updatedTime = document.getElementById('updated-time');
    if (updatedTime) {
      var text = updatedTime.textContent;
      var reg = /\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:Z|[+-]\d{2}:\d{2})/;
      var matchs = text.match(reg);
      if (matchs) {
        var relativeTime = moment(matchs[0]).fromNow();
        updatedTime.textContent = text.replace(reg, relativeTime);
      }
      updatedTime.style.display = '';
    }
  };
  Fluid.utils.createScript('https://lib.baomitu.com/moment.js/2.29.4/moment.min.js', function() {
    if (!'zh-cn'.startsWith('en')) {
      Fluid.utils.createScript('https://lib.baomitu.com/moment.js/2.29.4/locale/zh-cn.min.js', function() {
        relativeDate();
      });
    } else {
      relativeDate();
    }
  });
</script>


  
<script>
  Fluid.utils.createScript('https://lib.baomitu.com/tocbot/4.20.1/tocbot.min.js', function() {
    var toc = jQuery('#toc');
    if (toc.length === 0 || !window.tocbot) { return; }
    var boardCtn = jQuery('#board-ctn');
    var boardTop = boardCtn.offset().top;

    window.tocbot.init(Object.assign({
      tocSelector     : '#toc-body',
      contentSelector : '.markdown-body',
      linkClass       : 'tocbot-link',
      activeLinkClass : 'tocbot-active-link',
      listClass       : 'tocbot-list',
      isCollapsedClass: 'tocbot-is-collapsed',
      collapsibleClass: 'tocbot-is-collapsible',
      scrollSmooth    : true,
      includeTitleTags: true,
      headingsOffset  : -boardTop,
    }, CONFIG.toc));
    if (toc.find('.toc-list-item').length > 0) {
      toc.css('visibility', 'visible');
    }

    Fluid.events.registerRefreshCallback(function() {
      if ('tocbot' in window) {
        tocbot.refresh();
        var toc = jQuery('#toc');
        if (toc.length === 0 || !tocbot) {
          return;
        }
        if (toc.find('.toc-list-item').length > 0) {
          toc.css('visibility', 'visible');
        }
      }
    });
  });
</script>


  <script src=https://lib.baomitu.com/clipboard.js/2.0.11/clipboard.min.js></script>

  <script>Fluid.plugins.codeWidget();</script>


  
<script>
  Fluid.utils.createScript('https://lib.baomitu.com/anchor-js/4.3.1/anchor.min.js', function() {
    window.anchors.options = {
      placement: CONFIG.anchorjs.placement,
      visible  : CONFIG.anchorjs.visible
    };
    if (CONFIG.anchorjs.icon) {
      window.anchors.options.icon = CONFIG.anchorjs.icon;
    }
    var el = (CONFIG.anchorjs.element || 'h1,h2,h3,h4,h5,h6').split(',');
    var res = [];
    for (var item of el) {
      res.push('.markdown-body > ' + item.trim());
    }
    if (CONFIG.anchorjs.placement === 'left') {
      window.anchors.options.class = 'anchorjs-link-left';
    }
    window.anchors.add(res.join(', '));

    Fluid.events.registerRefreshCallback(function() {
      if ('anchors' in window) {
        anchors.removeAll();
        var el = (CONFIG.anchorjs.element || 'h1,h2,h3,h4,h5,h6').split(',');
        var res = [];
        for (var item of el) {
          res.push('.markdown-body > ' + item.trim());
        }
        if (CONFIG.anchorjs.placement === 'left') {
          anchors.options.class = 'anchorjs-link-left';
        }
        anchors.add(res.join(', '));
      }
    });
  });
</script>


  
<script>
  Fluid.utils.createScript('https://lib.baomitu.com/fancybox/3.5.7/jquery.fancybox.min.js', function() {
    Fluid.plugins.fancyBox();
  });
</script>


  <script>Fluid.plugins.imageCaption();</script>

  <script  src="/js/local-search.js" ></script>





<!-- 主题的启动项，将它保持在最底部 -->
<!-- the boot of the theme, keep it at the bottom -->
<script  src="/js/boot.js" ></script>


  

  <noscript>
    <div class="noscript-warning">博客在允许 JavaScript 运行的环境下浏览效果更佳</div>
  </noscript>
</body>
</html>
